草庐IT

java - 在Java中获取运行文件名?

全部标签

ruby - 使用 Rspec 2 和 Mocha 获取 Rails 3 生成器

我已经按照我能够在网上找到的使用Rspec2和Mocha配置Rails3的所有步骤进行操作。在我的Gemfile中:group:developmentdogem'rails3-generators'gem"rspec",'>=2.0.0.beta.19'gem"rspec-rails",'>=2.0.0.beta.19'endgroup:testdogem"faker"gem"rspec",'>=2.0.0.beta.19'gem"rspec-rails",'>=2.0.0.beta.19'gem"machinist",'>=2.0.0.beta1'gem"mocha"gem"capy

ruby open-uri打开方法丢失文件扩展名打开图片

我正在使用ruby​​1.9.2以及Rails3.1.4和Paperclip2.4.5。我的问题是尝试从URI保存回形针附件会丢失文件扩展名并保存文件而不会导致诸如需要扩展名的fancybox之类的问题。一些示例代码:uri="http://featherfiles.aviary.com/2012-06-13/bbe5f0de1/0c5a672b88ea47ecb4631ac173e27430.png"open(uri)#=>#因为临时文件上没有扩展名回形针正在保存文件而没有导致问题。有人遇到过这个问题吗?我已经看到关于使用回形针存储来自URI的图像的多个答案,但似乎没有一个解决我们正

ruby-on-rails - 如何构建我的 RSpec 测试文件夹、文件和数据库?

我已经使用RoR进行开发一年多了,但我才刚刚开始使用RSpec进行测试。对于标准模型/Controller测试,我通常没有任何问题,但问题是我想测试一些复杂的功能流程,并且不知道如何构建我的测试文件夹/文件/数据库。这是我的应用程序的基本结构:classCustomerhas_one:wallethas_many:ordershas_many:invoices,through::ordershas_many:invoice_summariesendclassWalletbelongs_to:customerendclassOrderhas_one:invoicebelongs_to:c

ruby - 如何调用在不同上下文中获取 block 的 Proc?

以这个例子为例:proc=Proc.new{|x,y,&block|block.call(x,y,self.instance_method)}它有两个参数,x和y,还有一个block。我想为自己使用不同的值来执行该block。像这样的东西几乎可以工作:some_object.instance_exec("xarg","yarg",&proc)但是,这不允许您传入一个block。这也行不通some_object.instance_exec("xarg","yarg",another_proc,&proc)也没有some_object.instance_exec("xarg","yarg"

ruby - 组织 Ruby 测试文件夹结构的最佳实践是什么?

在Java中,通常您会创建两个具有相同包层次结构的源文件夹src和test。在Ruby中,您是否只是将所有测试放在与被测类相同的文件夹中?还是在单独的文件夹中创建类似的层次结构?如果是这样,您如何管理单元测试中的require路径? 最佳答案 起初,每个gem都有一个典型的布局。代码几乎完全在lib中。在根目录中,只有README、gemspec文件和一些可选配置数据等元数据。如果您使用Rails或Sinatra之类的工具编写Web应用程序,则会改用它们的布局标准。尽管在所有这些项目类型中,都可以在相似的位置找到测试。根据您使用的测

ruby - 为什么 proc 可能比 block 运行得更快?

Thisanswer在另一个问题上说array.map(&:to_s)比快array.map{|n|n.to_s}在第一个例子中,&把:to_s变成一个Proc。第二个例子使用了一个block。为什么Proc在该基准测试中可能比block快?这种技术是否允许解释器进行一些优化? 最佳答案 这并不是关于“procvsblock”。下面是一个简单的实验(随意复制运行):require'benchmark'many=500array=(1..10000).to_aproc=proc{|a|a.to_s}Benchmark.bmdo|x|x

ruby - 如何从 Test::Unit::TestCase 获取堆栈跟踪

我正在测试一些Ruby代码并且有一个失败的Test::Unit::TestCase。不幸的是,失败报告只给我最上面的错误,而不是完整的堆栈跟踪。具体来说,它说:1)Failure:test_tp_make(TestScripts::TestTpMake)[test/test_scripts.rb:73]:Exceptionraised:>.引用的行号(73)是我的测试用例中assert_nothing_raised代码块的开始,它又开始了另一个代码块,该代码块又调用了一个大型库。我已经尝试使用--verbose标志运行测试,不幸的是这不会改变异常输出。我尝试查阅Test::Unit文档

Ruby:打开的文件太多@rb_sysopen

在使用File.new(big_file)打开一个文件(不关闭它)1016次(Ubuntu)或1017次(CentOS)后,似乎有一个限制并引发:Toomanyopenfiles@rb_sysopen-big_file(Errno::EMFILE)有什么办法可以提高这个限制吗?在我的系统上,ulimit设置为unlimited。 最佳答案 EMFILE是在您的进程中打开的文件太多。ENFILE是整个系统打开的文件太多。所以Errno::EMFILE是因为ruby​​进程打开了太多文件。此限制可能设置为默认1024可以看到:$ulim

ruby - cucumber 自动使用标签重新运行失败的场景?

在我们的构建中,某些情况会因我们无法控制的原因或正确调试所需的时间过长而失败。诸如异步javascript之类的东西。不管怎样,关键是有时他们工作有时他们不工作,所以我认为在场景中添加一个标签会很好,比如@rerun_on_failure或@retry,它会在失败之前重试场景X次构建。我知道这不是一个理想的解决方案,但测试仍然很有值(value),我们希望保留它而不会出现假阴性实际测试失败,点击链接并期望将跟踪事件发送到服务器进行分析(通过javascript)。有时selenium网络驱动程序加载下一页太快,事件没有时间发送。谢谢 最佳答案

ruby - 如何以编程方式一次运行多个 Rake 任务?

在命令行我可以像这样运行多个任务rakeenvironmenttask1task2task3我如何以编程方式执行此操作?我知道我可以像这样运行一项任务Rake::Task['task1'].invoke 最佳答案 你可以调用两个任务:require'rake'task:task1do|t|ptendtask:task2do|t|ptendRake::Task["task1"].invokeRake::Task["task2"].invoke我更喜欢有先决条件的新口味:require'rake'task:task1do|t|ptend